草庐IT

Python ArcPy批量掩膜、重采样大量遥感影像

全部标签

ruby - 如何在ruby中批量重命名文件

我一直在尝试编写一个基于ruby的文件重命名程序,作为我自己的编程练习(我知道linux下有rename,但我想学习Ruby,而rename在Mac中没有)。从下面的代码来看,问题是.include?方法总是返回false,即使我看到文件名包含这样的搜索模式。如果我注释掉include?检查,gsub()似乎根本不会生成新文件名(即文件名保持不变)。那么有人可以看看我做错了什么吗?提前致谢!这是预期的行为:假设当前文件夹下有三个文件:a1.jpg、a2.jpg、a3.jpgRuby脚本应该可以将其重命名为b1.jpg、b2.jpg、b3.jpg#!/Users/Antony/.rvm/

ruby - 快速处理大量 CSV 数据的最佳方式

我有大型CSV数据集(超过1000万行)需要处理。我有两个其他文件需要引用输出-它们包含的数据放大了我们对CSV文件中数百万行的了解。目标是输出一个新的CSV文件,其中每条记录都与来自其他文件的附加信息合并。假设大型CSV文件有交易,但客户信息和账单信息记录在另外两个文件中,我们想要输出一个新的CSV,其中每笔交易都链接到客户ID和账户ID等。一位同事有一个用Java编写的功能程序来执行此操作,但速度很慢。原因是数百万行的CSV文件显然要遍历很多很多次。我的问题是——是的,我已经开始了——我应该如何在Ruby中处理这个问题?目标是让它更快(现在18小时以上,CPU事件很少)我可以将这么

ruby-on-rails - 为 rails 中的所有记录批量缩减一个字段

当我第一次实现用户模型时,我允许用户输入大写或小写的电子邮件作为他们的登录信息。问题是它是一个移动应用程序,有时会发生自动上限,因此用户无法通过身份验证。我已经更改了CREATE方法以首先将电子邮件小写。但是,这会导致现有帐户的人不一致那么如何添加一个迁移来批量更新用户表中的电子邮件字段以将其小写? 最佳答案 最有效的方法是避免使用Ruby迭代器,而是直接在SQL中执行。在正常的迁移文件中,您可以将此SQL用于MySQL:execute("UPDATEusersSETemail=LOWER(email)")

sql - 从 Rails 4 应用程序调用大量 SQL

我有一个Rails4应用程序,我将它与sidekiq结合使用来运行异步作业。我通常在Rails应用程序之外运行的作业之一是大量复杂的SQL查询,这些查询实际上无法通过ActiveRecord建模。这组SQL查询与我的Rails应用程序的联系是它应该在我的Controller操作之一被调用时执行。理想情况下,我会在Controller中将我的Rails应用程序的作业排队,以便Sidekiq继续运行查询。现在它们存储在一个外部文件中,我不完全确定让Rails运行上述SQL的最佳方法是什么。感谢任何解决方案。 最佳答案 我同意Sharag

ruby-on-rails - 为什么对 params 哈希进行切片会对批量分配造成安全问题?

通过批量分配防止安全风险的官方方法是使用attr_accessible.然而,一些程序员认为这不是模型的工作(或者至少不是仅模型的工作)。在Controller中执行此操作的最简单方法是对params哈希进行切片:@user=User.update_attributes(params[:user].slice(:name))但是文档指出:NotethatusingHash#exceptorHash#sliceinplaceofattr_accessibletosanitizeattributeswon’tprovidesufficientprotection.这是为什么呢?为什么par

ruby - Emacs ruby​​ 模式,在括号内大量缩进?

请原谅我的emacs新手,但有人知道如何解决这个问题吗?在emacs中编码时,在ruby​​模式下,它会在所有关键字之后缩进到正确的级别(即2个空格),如def、class、module、begin等,但是当跨多行打破参数列表时,它会缩进到一个看似随机的位置,比如超过40列左右。我一直在阅读emacs选项卡设置,似乎只是在兜圈子,没有获得我正在寻找的信息,所以我想我应该在这里问。这是将光标放置在参数列表中的屏幕截图。我试过在大括号内缩进(例如,对于一个block或一个散列)并且它工作正常,是括号把它弄乱了。 最佳答案 http://

ruby - 有效地处理数字数组的 "scale"或 "resize"的算法(音频重采样)

做音频处理(虽然它也可以是图像处理)我有一个一维数字数组。(它们恰好是代表音频样本的16位有符号整数,这个问题同样适用于float或不同大小的整数。)为了匹配不同频率的音频(例如,将44.1kHz样本与22kHz样本混合),我需要拉伸(stretch)或压缩值数组以满足特定长度。将数组减半很简单:每隔一个样本丢弃一次。[231,8143,16341,2000,-9352,...]=>[231,16341,-9352,...]将数组宽度加倍稍微不那么简单:将每个条目加倍(或可选地在相邻的“真实”样本之间执行一些插值)。[231,8143,16341,2000,-9352,...]=>[2

ruby - Rails,如何迁移大量数据?

我有一个运行旧版本Spree(开源购物车)的Rails3应用程序。我正在将它更新到最新版本。这需要我在数据库上运行大量迁移以与最新版本兼容。但是,应用程序当前的数据库大约为300mb,要在我的本地计算机(macosx10.7、4gbram、2.4GHzCore2Duo)上运行迁移需要三天以上的时间才能完成。我能够使用AmazonEC2实例(高I/O按需实例,四倍超大)将这个时间减少到仅16小时。但是16小时仍然太长,因为我必须关闭网站才能执行此更新。有没有人有任何其他建议来降低这个时间?或提高迁移性能的任何提示?仅供引用:在Amazon实例上使用Ruby1.9.2和Ubuntu。

ruby - Controller 中批量更新的最佳实践

我想知道在Controller中允许批量编辑/更新的最佳做法是什么。我真的找不到关于这个主题的文章或指南。 最佳答案 我看到您用REST标记了您的问题。要以REST方式执行此操作,您需要将集合或更新本身视为资源。假设您正在使用Product对象。您可能会PUT到/product_batches/[someidentifier],这会调用ProductBatchesController#update,但随后您会想知道[someidentifier]中的内容。您可以将ProductBatch设为singularresource这样您就不

ruby-on-rails - 有没有办法绕过批量分配保护?

我有一个Rails3应用程序,它对对象进行JSON编码,以便将它们存储在Redis键/值存储中。当我检索对象时,我尝试解码JSON并从数据中实例化它们,如下所示:defdecode(json)self.new(ActiveSupport::JSON.decode(json)["#{self.name.downcase}"])end问题是这样做涉及批量分配,这是不允许的(我被告知有充分的理由!)对于我没有赋予attr_writer能力的属性。有没有办法只针对此操作绕过批量分配保护? 最佳答案 assign_attributeswith